package it.unipd.dei.bd.icineasti.servlet;

import it.unipd.dei.bd.icineasti.database.GetEventoDatabase;
import it.unipd.dei.bd.icineasti.resource.Evento;
import it.unipd.dei.bd.icineasti.resource.Film;

import java.io.IOException;
import java.io.PrintWriter;
import java.sql.Connection;
import java.sql.SQLException;
import java.sql.Date;
import java.util.List;

import javax.naming.InitialContext;
import javax.naming.NamingException;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.sql.DataSource;

/**
 * Servlet per il caricamento dei dettagli di un evento per la pagina scheda_evento
 * Necessita del parametro d'ingresso codiceEvento
 * 
 * @author Morris Antonello
 *
 */
public class GetEventoServlet extends AbstractDatabaseServlet {

	public void doGet(HttpServletRequest req, HttpServletResponse res)
			throws ServletException, IOException {

		// imposta il tipo MIME della risposta
		res.setContentType("text/html");

		// ottiene un flusso di uscita per scrivere la risposta
		PrintWriter out = res.getWriter();

		Connection con = null;

		try {
			con = DS.getConnection();
			Evento evento = null;
			int codiceEvento = Integer.parseInt(req.getParameter("codiceEvento"));
			evento = new GetEventoDatabase(con, codiceEvento).getEvento();
			
			out.printf("var descrittoreEvento = new Array(%s); ", 13);
			
			out.printf("descrittoreEvento[0] = \"%s\"; ", evento.getCodice());
			out.printf("descrittoreEvento[1] = \"%s\"; ", evento.getLocandina());
			out.printf("descrittoreEvento[2] = \"%s\"; ", evento.getTitolo());
			out.printf("descrittoreEvento[3] = \"%s\"; ", evento.getDescrizione());
			out.printf("descrittoreEvento[4] = \"%s\"; ", evento.getDurataInSala());
			// out.printf("descrittoreEvento[5] = \"%s\"; ", evento.getDurataProiezione());
			out.printf("descrittoreEvento[6] = \"%s\"; ", ((Film)evento).getTrama());
			// out.printf("descrittoreEvento[7] = \"%s\"; ", ((Film)evento).getGenere());
			out.printf("descrittoreEvento[8] = \"%s\"; ", ((Film)evento).getRegia());
			out.printf("descrittoreEvento[9] = \"%s\"; ", ((Film)evento).getCastPrincipale());
			out.printf("descrittoreEvento[10] = \"%s\"; ", ((Film)evento).getUrlTrailer());
			// out.printf("descrittoreEvento[11] = \"%s\"; ", ((Film)evento).getDataUscita());
			out.printf("descrittoreEvento[12] = \"%s\"; ", true);

		} catch (NullPointerException e) {
			// messaggio d'errore
			out.printf("<p><center><font color=\"red\" size=\"+2\">Impossibile creare la connessione al database.</font></center></p>");
		} catch (SQLException e) {
			// messaggio d'errore
			out.printf("<p><center><font color=\"red\" size=\"+2\">Errore durante l'accesso al database: %s</font></center></p>",
			e.getMessage());
		} catch (ClassCastException e) {
			out.printf("descrittoreEvento[9] = \"%s\"; ", false);
		}
		
		out.printf("return descrittoreEvento; ");

		// assicura che tutto il contenuto sia inviato
		out.flush();

		// chiude il flusso di uscita
		// out.close();

	}

}
